package com.atguigu.crowd.mvc.config;

import com.atguigu.crowd.entity.Admin;
import org.springframework.security.core.GrantedAuthority;
import org.springframework.security.core.userdetails.User;

import java.util.List;

/**
 * 考虑到User对象中仅仅包含账号和密码，为了能够获取到原始的Admin对象，专门创建这个类对User类进行扩展
 *
 * @author wmb
 *
 * @since 2021-1-29
 */
public class SecurityAdmin extends User {

    private static final long serialVersionUID = 1L;

    /**
     * 原始的Admin对象，包含Admin对象的全部属性
     */
    private Admin originalAdmin;

    public SecurityAdmin(
                    // 传入原始的Admin对象
                    Admin originalAdmin,
                    // 创建角色、权限信息的集合
                    List<GrantedAuthority> authorityList) {
        // 调用父类构造器
        super(originalAdmin.getLoginAccount(), originalAdmin.getUserPassword(), authorityList);
        // 给本类的this.originalAdmin赋值
        this.originalAdmin = originalAdmin;
        // 将原始Admin对象中的密码擦除
        this.originalAdmin.setUserPassword(null);
    }

    /**
     * 对外提供的获取原始Admin对象的getXXX()方法
     *
     * @return
     */
    public Admin getOriginalAdmin() {
        return originalAdmin;
    }
}
